9974
20752
Most telepítettem a Python 3.6.1-et MacOS X-re
Amikor megpróbálom futtatni a konzolt (vagy bármit futtatok a Python3 alkalmazással), a következő hiba lép fel:
AttributeError: Az 'enum' modulnak nincs attribútuma 'IntFlag'
$ /Library/Frameworks/Python.framework/Versions/3.6/bin/python3
Nem sikerült importálni a helymodult
Traceback (a legutóbbi hívás utoljára):
Fájl "/usr/local/Cellar/python3/3.6.1/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site.py" 544. sor a 
fő()
Az "/usr/local/Cellar/python3/3.6.1/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site.py" fájl 530. sora, fő
ismert_útvonalak = addusersitepackages (ismert_útvonalak)
"/Usr/local/Cellar/python3/3.6.1/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site.py" 282. sor fájl az addusersitepackages fájlban
user_site = getusersitepackages ()
"/Usr/local/Cellar/python3/3.6.1/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site.py" 258. sor fájl a getusersitepackages
user_base = getuserbase () # ez a USER_BASE értéket is beállítja
"/Usr/local/Cellar/python3/3.6.1/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site.py" 248. sor fájl a getuserbase-ben
USER_BASE = get_config_var ('userbase')
"/Usr/local/Cellar/python3/3.6.1/Frameworks/Python.framework/Versions/3.6/lib/python3.6/sysconfig.py" fájl, 601. sor, a get_config_var fájlban
return get_config_vars (). get (név)
"/Usr/local/Cellar/python3/3.6.1/Frameworks/Python.framework/Versions/3.6/lib/python3.6/sysconfig.py" 580. sor fájl a get_config_vars fájlban
import _osx_support
Fájl: "/usr/local/Cellar/python3/3.6.1/Frameworks/Python.framework/Versions/3.6/lib/python3.6/_osx_support.py" 4. sor, a
import re
Fájl "/usr/local/Cellar/python3/3.6.1/Frameworks/Python.framework/Versions/3.6/lib/python3.6/re.py" 142. sor a 
osztály RegexFlag (enum.IntFlag):
AttributeError: Az 'enum' modulnak nincs attribútuma 'IntFlag'
Az IntFlag osztály az enum.py fájlon belül található. Szóval, miért dobják az AttributeError-t? 
Ez azért van, mert az enum nem a szokásos könyvtár enum modul. Valószínűleg telepítve van az enum34 csomag.
Az egyik módja annak ellenőrzésére, hogy megvizsgálja-e az ingatlant .__ file__
import enum
nyomtatás (enum .__ file__)
# a könyvtár általános helyének valami hasonlónak kell lennie
# /usr/local/lib/python3.6/enum.py
A python 3.6 óta az enum34 könyvtár már nem kompatibilis a standard könyvtárral. A könyvtár szintén felesleges, ezért egyszerűen eltávolíthatja.
pip uninstall -y enum34
Ha a kódra a python verziók <= 3.4 és> 3.4 futtatásához is szüksége van, akkor megpróbálhatja követelményként megadni az enum -ompatibilitást. Csak az enum34-et telepíti a Python régebbi verzióihoz a szokásos könyvtár-enum nélkül.
|
Nem biztos abban, hogy továbbra is fennáll-e ez a probléma. Hasonló problémám volt, és egyszerűen megoldani tudtam a PYTHONPATH kikapcsolásával
$ unset PYTHONPATH
|
Számomra ez a hiba az app-engine-python gcloud komponens telepítése után történt, hogy integrálódhassak a pycharmba. A modul eltávolítása segített, még akkor is, ha a pycharm most nem tölt fel app-engine-be.
|
Ha valaki azért jön ide, mert ezt a hibát tapasztalja, miközben Python 3.7 szabványos környezeti projektet futtat a PyCharmban, akkor csak annyit kell tennie, hogy
Győződjön meg arról, hogy a futtatni kívánt konfiguráció az Lombikra vonatkozik, nem pedig a Google App Engine konfigurációjára.
Ezután tiltsa le a Google App Engine támogatást a Beállítások >> Nyelvek és keretrendszer >> Google App Engine alatt
Ennek oka ez a link
Az általános cél az, hogy alkalmazásának teljes mértékben hordozhatónak és bármilyen szabványos Python-környezetben fusson legyen. Szabványos Python alkalmazást írsz, nem App Engine Python alkalmazást. Ennek a váltásnak a részeként többé nem kell használnia saját App Engine API-kat és szolgáltatásokat az alkalmazás alapvető funkcióihoz. Jelenleg az App Engine API-k nem érhetők el a Python 3.7 futás közben.
Gondolom, amikor létrehozunk egy Python 3.7 projektet a PyCharmban, mint egy Google alkalmazás motor projektet, akkor is ugyanúgy próbálkozik, mint egy python2.7 alkalmazásnál
|
NYILATKOZAT: Kérjük, @ juanpa.arrivillaga, ha látja ezt a választ, nyugodtan írja meg a sajátját, és eltávolítom ezt a bejegyzést.
@ juanpa.arrivillaga fentebb említette:
Van véletlenül az enum.py fájlnév a munkakönyvtárban?
Ez volt az a kérdés, amivel találkoztam. Akkor még nem volt tudomásom a python enum moduljáról, és a tesztfájlomat enum.py néven neveztem el.
Mivel a fájlnév a modul neve, ütközés történt. További információ a modulokról itt: https://docs.python.org/2/tutorial/modules.html
|
A "Google App Engine Support" letiltása a pycharm beállításaiban megoldotta ezt a problémát.
|
Az enum34 1.1.8 verziójának telepítése nekem bevált.
Ezt úgy tudtam kijavítani, hogy az enum34 = "== 1.1.8" -t hozzáadtam a pyproject.toml fájlhoz.
Nyilván az enum34-nek volt olyan jellemzője a v1.1.8-ban, amely elkerülte ezt a hibát, de
ez visszafejlődött a v1.1.9 + verzióban. Ez azonban csak egy megoldás. A
jobb megoldás lenne, ha a csomagok környezetjelzőket használnának
egyáltalán nem kell telepítenie az enum34-et, csak ha szükséges.
Forrás: https://github.com/python-poetry/poetry/issues/1122
|
Håken Lid válasza segített megoldani a problémámat (köszönöm!), Az én esetemben a Python3.7-ben jelen volt, amikor a Lombikot Docker-tárolóban futtattam (FROM tiangolo / uwsgi-nginx-flask: python3.7-alpine3.7).
Az én esetemben az enum34-et egy másik könyvtár telepítette (pip install smartsheet-python-sdk).
Azok számára, akik hasonló Docker konténerproblémával érkeznek, itt van a végső Dockerfájlom (a megfelelő sorokra leszerelve):
Tiangolo / uwsgi-nginx-lombikból: python3,7-alpesi3,7
...
RUN pip install -r követelmények.txt
RUN pip uninstall -y enum34
...
|
Abban az esetben, ha meg kell tartania a PYTHONPATH-t mind a python2, mind a python3 esetében, álneves utasításokat írhat a megfelelő PYTHONPATH beállításához a bash_profile-ban:
Kódolja be a PYTHONPATH2 és PYTHONPATH3 változóit a ~ / .bash_profile fájljába, és adja hozzá a következő álneveket a végén:
alias python = 'export PYTHONPATH = $ {PYTHONPATH2}; python'
alias python3 = 'export PYTHONPATH = $ {PYTHONPATH3}; python3'
A pythonom (a python2-re utal), mivel gyakrabban használom a python2-t.
|
Amikor valaha is felmerült ez a probléma:
AttributeError: Az 'enum' modulnak nincs attribútuma 'IntFlag'
egyszerűen először futtatom a parancsot:
hatástalanítani PYTHONPATH
majd futtasd a kívánt parancsomat, majd ebben sikert arattam.
|
A pip install  --ignore-install enum34 használatával csináltam
Miután telepítette a szükséges könyvtárat, keresse meg a figyelmeztetéseket az összeállítás során.
Ilyen hibát kaptam: A régi setup.py telepítés használata a jövőben, mivel a 'wheel' csomag nincs telepítve ERROR: a pyejabberd 0.2.11 követelménye az enum34 == 1.1.2, de az enum34 1.1.10 verzió nem kompatibilis .
A probléma megoldásához futtassa a következő parancsot: pip freeze | grep enum34. Ez megadja a telepített enum34 verzióját. Most távolítsa el a pip uninstall enum34 segítségével, és telepítse újra a szükséges verziót, mivel pip install "enum34 == 1.1.20"
|
Ha a PyCharm tesztek futtatásakor jelentkezik ez a probléma, ellenőrizze, hogy a második négyzet nincs bejelölve akonfigurációk.
|
A számítógépemre telepítve van a Python 2 és a Python 3. Valami furcsa oknál fogva a Python 3 sys.path-jában van egy elérési út a Python2 sitepackage könyvtár könyvtárához is, amikor az re modult meghívják. Ha futtatom a Python 3-at, és importálom az enumot, és kinyomtatom (enum .__ file__), a rendszer nem jeleníti meg ezt a Python 2 elérési utat a site-csomagokhoz. Tehát nagyon durva és piszkos feltörés az a modul közvetlen módosítása, amelyben az enum importálásra kerül (kövesse a traceback útvonalait), és a következő kódot illessze be közvetlenül az enum importálása előtt:
import sys
i-re, p a felsorolásban (sys.path):
ha a "python27" a p.lower () vagy a "python2.7" a p.lower () mezőben: sys.path.pop (i)
import enum
Ez megoldotta a problémámat.
|
Még nekem is felmerült ez a probléma a python -m grpc_tools.protoc --version futtatása közben
Be kellett állítanom a PYTHONPATH-t a site-csomagokig, és le kellett állítania az összes parancssori ablakot, és működött. Remélem, hogy segít a gRPC felhasználók számára.
|
Ez a probléma az ubuntu20.04-ben volt a jupyterlab-ban a virtuális env kernelemben python3.8 és tensorflow 2.2.0 fájlokkal. Hibaüzenet volt
Traceback (a legutóbbi hívás utoljára):
"/Usr/lib/python2.7/runpy.py" fájl, 174. sor, _run_module_as_main
"__main__", fname, loader, pkg_name)
"/Usr/lib/python2.7/runpy.py" fájl, 72. sor, _run_code
exec kód a run_globals fájlban
Fájl: "/home/hu-mka/.local/lib/python2.7/site-packages/ipykernel_launcher.py" 15. sor, a 
az ipykernel alkalmazásból importálja a kernelapp alkalmazást
A "/home/hu-mka/.local/lib/python2.7/site-packages/ipykernel/__init__.py" fájl 2. sorának fájlja a 
innen .connect import *
Fájl: "/home/hu-mka/.local/lib/python2.7/site-packages/ipykernel/connect.py" 13. sor, a 
az IPython.core.profiledir fájlból importálja a ProfileDir fájlt
Fájl: "/home/hu-mka/.local/lib/python2.7/site-packages/IPython/__init__.py" 48. sor, a
from .core.application import alkalmazás
Fájl "/home/hu-mka/.local/lib/python2.7/site-packages/IPython/core/application.py" 23. sor, a 
from traitlets.config.application import alkalmazás, catch_config_error
Fájl "/home/hu-mka/.local/lib/python2.7/site-packages/traitlets/__init__.py" 1. sor, a 
a .traitlets importból *
A "/home/hu-mka/.local/lib/python2.7/site-packages/traitlets/traitlets.py" 49. sor fájl a 
import enum
ImportError: Nincs enum nevű modul
A probléma az volt, hogy az / usr / bin / python könyvtárban található szimbolikus linkben a python2-re mutatott. Megoldás:
cd / usr / bin /
sudo ln -sf python3 python
Remélhetőleg a Python 2 használata hamarosan teljesen leáll.
|
Ezt a problémát akkor kaptam, amikor a transzformátor könyvtárat telepítettem a HuggingFace-től. Ennek oka az volt, hogy az enum34 csomagot telepítették a környezetembe, amely felülírta a beépített enumot a Pythonban. Ezt a csomagot valószínűleg valami olyan telepítette, mint az előre történő kompatibilitás, amelyre már nincs szükség a Python 3.6+ verzióval. Tehát a megoldás egyszerűen:
pip uninstall -y enum34
|
Sajnos egyik javaslat sem segített nekem, de néhány további googlelés után
pip install aenum
megoldotta nekem
|
Ha valakinek ilyen problémája van, amikor megpróbálja a Jupyter kernelt futtatni egy virtualenv-ből, egyszerűen adja hozzá a helyes PYTHONPATH-t a virtualenv kernel kernel.json fájljához (például Python 3):
{
"argv": [
"/usr/local/Cellar/python/3.6.5/bin/python3.6",
"-m",
"ipykernel_launcher",
"-f",
"{connection_file}"
],
"display_name": "Python 3 (TensorFlow)",
"nyelv": "python",
"env": {
"PYTHONPATH": "/Users/dimitrijer/git/mlai/.venv/lib/python3.6:/Users/dimitrijer/git/mlai/.venv/lib/python3.6/lib-dynload:/usr/local/ Cellar / python / 3.6.5 / Frameworks / Python.framework / Versions / 3.6 / lib / python3.6: /Users/dimitrijer/git/mlai/.venv/lib/python3.6/site-packages "
}
}
|
A válaszod
StackExchange.ifUsing ("editor", function () {
StackExchange.using ("externalEditor", function () {
StackExchange.using ("kivonatok", function () {
StackExchange.snippets.init ();
});
});
}, "kódrészletek");
StackExchange.ready (function () {
var channelOptions = {
címkék: "" .split (""),
id: "1"
};
initTagRenderer ("". split (""), "" .split (""), channelOptions);
StackExchange.using ("externalEditor", function () {
// A szerkesztőt töredékek után kell indítania, ha a kivonatok engedélyezve vannak
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using ("kivonatok", function () {
createEditor ();
});
}
más {
createEditor ();
}
});
function createEditor () {
StackExchange.prepareEditor ({
useStacksEditor: hamis,
heartbeatType: 'válasz',
autoActivateHeartbeat: hamis,
convertImagesToLinks: true,
noModals: igaz,
showLowRepImageUploadWarning: igaz,
reputációToPostImages: 10,
bindNavPrevention: igaz,
postfix: "",
imageUploader: {
brandingHtml: "Powered by \ u003ca href = \" https: //imgur.com/ \ "\ u003e \ u003csvg class = \" svg-icon \ "width = \" 50 \ "height = \" 18 \ "viewBox = \ "0 0 50 18 \" fill = \ "none \" xmlns = \ "http: //www.w3.org/2000/svg \" \ u003e \ u003cpath d = \ "M46.1709 9.17788C46.1709 8.26454 46.2665 7.94324 47.1084 7.58816C47.4091 7.46349 47.7169 7.36433 48.0099 7.26993C48.9099 6.97997 49.672 6.73443 49.672 5.93063C49.672 5.22043 48.98324,61182 48,1414 4.61182C47.4335 4,61182 4,91628 46,7256 46,0943 5.50789C45.7307 4,9328 45,2525 4,66231 44,6595 4.66231C43.6264 4,66231 5,28821 43,1481 43,1481 6.59048V11.9512C43.1481 13,2535 43,6264 13,8962 44,6595 13.8962C45.6924 13,8962 46,1709 13,2535 46,1709 11.9512V9.17788Z \” / \ u003e \ u003cpath d = \ "M32.492 10.1419C32.492 12.6954 34.1182 14.0484 37.0451 14.0484C39.9723 14.0484 41.5985 12.6954 41.5985 10.1419V6.59049C41.5985 5.28821 41.1394 4.662323940 4.6623240 4061 .5948 10.8521 38.2696 11.5455 37.0451 11.5455C35.8209 11.5455 35.4954 10.8521 35.4954 9.60062V6.59049C35.4954 5.28821 35.0173 4.66232 34.0034 4.66232C32.9703 4.66232 32.492 5.28821 324 \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ "clip-rule = \" evenodd \ "d = \" M25.6622 17.6335C27.8049 17.6335 29.3739 16.9402 30.2537 15.6379C30.8468 14.7755 30.9615 13.5579 30.9615 11.9512V6.59049C30.9615 5.28821 30.4833 4.66231 4 462 312 462 3166 4.9497 8 28.1109 5.50789C27.499 4.86533 26.7335 4.56087 25.7005 4.56087C23.1369 4.56087 21.0134 6.57349 21.0134 9.27932C21.0134 11.9852 23.003 13.913 25.3754 13.913C26.5612 13.913 27.4607 13.4902 28.1109 12.11 211 12.983C28.1301 14,4373 27,2502 15,2321 25,777 15.2321C24.8349 15,2321 24,1352 14,9821 23,5661 14.7787C23.176 14,6393 22,8472 14,5218 22,5437 14.5218C21.7977 14,5218 21,2429 15,0123 21,2429 15.6887C21.2429 16,7375 22,9072 17,6335 25,6622 17.6335ZM24.1317 9.27932C24.1317 7,94324 24,9928 7.09766 26.1024 7.09766C27.2119 7.09766 28.0918 7.94324 28.0918 9.27932C28.0918 10.6321 27.2311 11.5116 26.1024 11.5116C24.9737 11.5116 24.1317 10.6491 24.1317 9.27932Z \ "/ \ u003e \ u003c12 \ u003cath = u 1100 13.8962C19.3298 13.8962 19.8079 13.2535 19.8079 11.9512V8.12928C19.8079 5.82936 18.4879 4.62866 16.4027 4.62866C15.1594 4.62866 14.279 4.98375 13.3609 5.88013C12.653 5.05154 11.6581 4.62866 10.3573 4.62866C9.34336 4.62866 8.57809 4.89931 7.9466 5.5079C7.58314 4.9328 7.10506 4.66232 6.51203 4.66232C5.47873 4.66232 5.00066 5.28821 5.00066 6.59049V11.9512C5.00066 13.253.32 133133 213133 213132 213 0232 7.58817 8.44431 6.91179 9.53458 6.91179C10.5104 6.91179 10.893 7.58817 10.893 8.94108V11.9512C10.893 13.2535 11.3711 13.8962 12.4044 13.8962C13.4375 13.8962 13.9157 13.2535 13.9157 7139 7139 7159 11 7159 11 7 V11.9512Z \ "/ \ u003e \ u003cp d = \" M3.31675 6.59049C3.31675 5.28821 2.83866 4.66232 1.82471 4.66232C0.791758 4.66232 0.313354 5.28821 0.313354 6.59049V11.9512C0.313354 13.2535 0.79 3.31675 11.9512V6.59049Z \ "/ \ u003e \ u003cpath d = \" M1.87209 0.400291C0.843612 0.400291 0 1.1159 0 1.98861C0 2.87869 0.822846 3.57676 1.87209 3.57676C2.90056 3.57676 3.7234 2.8786 3.7234 1.98861C3.7234 1.1159 2.90056 0.400291 1.87209 0.400291Z \ "fill = \" # 1BB76E \ "/ \ u003e \ u003c / svg \ u003e \ u003c / a \ u003e",
contentPolicyHtml: "Felhasználói hozzájárulások a (z) \ u003ca href = \" licenc alatt vannak engedélyezve / legal / content-policy \ "\ u003e (tartalmi irányelv) \ u003c / a \ u003e",
allowUrls: igaz
},
onDemand: igaz,
discardSelector: ".discard-answer"
, azonnalShowMarkdownHelp: true, enableTables: true, enableSnippets: true
});
}
});
Köszönjük, hogy közreműködött a Stack Overflow válaszában!
Kérjük, feltétlenül válaszoljon a kérdésre. Adjon meg részleteket és ossza meg kutatását!
De kerüld ...
Kérjen segítséget, pontosítást vagy válaszoljon más válaszokra.
Nyilatkozatok tétele vélemény alapján; támassza alá őket referenciákkal vagy személyes tapasztalatokkal.
Ha többet szeretne megtudni, olvassa el a nagyszerű válaszok megírásával kapcsolatos tippjeinket.
Piszkozat mentve
Piszkozat eldobva
Regisztráljon vagy jelentkezzen be
StackExchange.ready (function () {
StackExchange.helpers.onClickDraftSave ('# login-link');
});
Regisztráljon a Google segítségével
Regisztráljon a Facebook segítségével
Regisztráljon az E-mail és a Jelszó használatával
Beküldés
Hozzászólás vendégként
Név
Email
Kötelező, de soha nem látható
StackExchange.ready (
függvény () {
StackExchange.openid.initPostLogin ('. New-post-login', 'https% 3a% 2f% 2fstackoverflow.com% 2fquestions% 2f43124775% 2fwhy-python-3-6-1-throws-attributeerror-module-enum-has- no-attribute-intflag% 23new-answer ',' question_page ');
}
);
Hozzászólás vendégként
Név
Email
Kötelező, de soha nem látható
Tegye közzé válaszát
Dobd el
A „Válasz elküldése” gombra kattintva elfogadja az Általános Szerződési Feltételeinket, az adatvédelmi irányelveket és a cookie-kat
Nem a keresett válasz? Böngésszen a python python-3.x címkével ellátott többi kérdésben, amely felsorolja a python-3.6 attributeerror hibát, vagy tegye fel saját kérdését.